<template>
  <component
    :is="getComponentName()"
    v-model="value"
    :placeholder="props.component.formType === 'range' ? ['请选择开始时间', '请选择结束时间'] : `请选择${props.component.title}`"
    :time-picker-props="props.component.formType === 'range' ? { defaultValue: ['00:00:00', '23:59:59'] } : {}"
    :show-time="props.component.showTime"
    :type="props.component.range ? (props.component.formType === 'time' ? 'time-range' : 'range') : ''"
    :format="props.component.format || ''"
    :mode="props.component.mode"
    allow-clear
    style="width: 100%"
  />
</template>

<script setup>
import { get, set } from "lodash";

const props = defineProps({
  component: Object
});
const searchForm = inject("searchForm");
const emit = defineEmits(["update:modelValue"]);

const getComponentName = () => {
  if (["date", "month", "year", "week", "quarter", "range", "time"].includes(props.component.formType)) {
    return `a-${props.component.formType}-picker`;
  }
};

const value = computed({
  get() {
    let val = get(searchForm.value, props.component.dataIndex);
    if (val === undefined) {
      if (props.component.formType === "range") {
        val = props.component.searchDefaultValue ?? [];
      } else {
        val = props.component.searchDefaultValue ?? "";
      }
    }

    return val;
  },
  set(newVal) {
    if (newVal === undefined) {
      if (props.component.formType === "range") {
        newVal = [];
      } else {
        newVal = "";
      }
    }

    emit("update:modelValue", newVal);
    set(searchForm.value, props.component.dataIndex, newVal);
  }
});
</script>
